-
-
Notifications
You must be signed in to change notification settings - Fork 840
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: date time formats from locales #4029
Conversation
I have another question, because we are adding features in Flarum core, can we make this feature more configurable? such as > new Intl.DateTimeFormat('zh-TW-u-ca-roc', { year: 'numeric', month: 'long', day: 'numeric', }).format(new Date(2025, 4, 14));
'民國114年5月14日' so I prefer that we make a flarum extender thus language-pack or something else plugin can define a new format. |
This is possible with the version in my working tree. But I don't see the possible use cases. |
I see what you mean, the problem is that this PR only solves the hardcoded format problem with Flarum and DayJS's Localized Format plugin. The feature you requested needs a big change to how Flarum and DayJS work. |
make sense |
Note that there was some discussion about it in: https://discuss.flarum.org/d/22913-what-date-format-do-you-use As for the problem, I would much more prefer format defined as part of forum translation, like: ago = d.format(app.translator.trans('core.forum.date-format.humanTimeShort')); It will be easier to understand and maintain for language pack maintainers, and you can quite easily adjust it also as a forum owner. And overall it seems to be simpler and less hacky solution than introducing some cryptic |
I think this is kinda messy since you have one set of formats in DayJS that cannot be easily edited by forum owners and another set of formats in Flarum locale system. This is the reason I didn't implement it in this way at the beginning. |
I'm not sure what the problem is. Most language packs copied dayjs translations from the source without any changes (I actually had plans to automate it and fetch updates automatically from dayjs repo). This format can be quite cryptic and tricky to change, but there is no really other way to translate dayjs. If your solution relies on editing dayjs translations, then it inherits all its problems: it is more problematic for language pack maintainers and much harder to override by forum owners. On the other hand, if we use |
Actually, my latest code on my working tree already removed the Localized Format plugin from DayJS, so it's possible to make it also use the formats available in the language pack instead of the one from DayJS locale. In this way, the priority of the format can become like this: So we can make all formats available in DayJS Localized Format plugin and the ones that Flarum uses editable in Flarum's translator. Does this sound good to you? |
Some details of the changes made still need some discussion, the PR is now a draft. |
chore: fetch format from translator
@rob006 I've pushed new changes, would you like to check if it looks good to you? I haven't tested it yet. |
0092d89
to
6782636
Compare
Is there any reason why you implemented this in this way instead of passing |
I just did what DayJS did to implement the localized format and make it work with Flarum. Also made it extendable. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the PR! much appreciated!
I think the FF ff formats with the dayjs plugin will only add to the confusion with date time formats and future maintenance.
I'm going to propose something a little more simple but more clear.
Let's add a format(format: string, datetime: Dayjs)
to the Translator
class in common.
this method would:
- check if the provided format exists in a custom item list (
customFormats()
) and use that. - Fallback to
app.translator.trans('core.lib.datetime_formats.'+format)
- Fallback to the actual format.
There are a lot of different formats used throughout the app, (+extensions) so this would give language packs more power over how those formats are changed.
The locale would be literally the format as a key, so:
core:
lib:
datetime_formats:
"h A": "h A"
"MMMM YYYY": "MMMM YYYY"
"YYYY-MM-DD": "YYYY-MM-DD"
"YYYY-MM-DD h:mm A": "YYYY-MM-DD h:mm A"
"YYYY-MM-DD h:mm:ss A": "YYYY-MM-DD h:mm:ss A"
"LL": "LL"
"LLL": "LLL"
"LLLL": "LLLL"
core would have one single example commented out. While language packs can fill more entries as needed.
The new method would be called like so:
app.translator.format('MMMM YYYY', datetime)
@YUCLing @rob006 what do you think? do we see any potential issues with that approach?
@SychO9 I think it would be much more practical and intuitive to override/translate format used in specific situation/place, than just overwrite dayjs formats. For example in Polish language pack I would prefer to use @YUCLing Sorry, it looks overcomplicated to me and I don't see a practical reason to implement this in that way. |
@rob006 if you want an extension like that, that's up to you. Not every forum needs more than 1 language, so for many it's a valid use case. Point is, this is for custom behavior. Up to the developer/webmaster to determine what they want, up to the dev to make it happen. We just enable proper ways of extending behavior/components. Rather than leave things to hacking up the code. This enables us to make changes to the core code without worrying constantly about breaking backwards compatibility. |
Co-authored-by: Sami Mazouz <[email protected]>
@SychO9 My point is: if we don't know exactly how it is supposed to be used, then maybe adding an API to cover use case we don't fully understand may be a dead end and will require some adjustments in the future (this may result a BC break). It is already possible to adjust date formats by overriding translations, so you don't even need dedicated extension, you can use Linguist for that. So @YUCLing Can we have this PR against 1.x branch? |
OK, I checked new implementation and now I'm even more confused. I assumed that |
@rob006 but I gave you a simple valid use case. For the user to be able to fill the formats themselves as a preference. I understand it is not something you personally see the point in. This is something I can do in other forum software as well and isn't all that odd. Also, even without this a developer could still make it happen. But by modifying parts of the code that we consider private API. What we add here is a public API where even if we make changes to the code in the future, allows us to prevent BC breaks by handling the item list as necessary. |
And IMO this is a wrong place to cover this use case. I does not allow you to remove "2 minutes ago" format and use precise date instead (for example I can do this in phpBB). I we want the ability to change date format used by forum it makes more sense to override |
BTW: #4053 just got merged to 1.x branch, so I guess there is no point to rebase this PR and we can leave 2.x as target. |
Sorry but that's just a different use case. It does not invalidate the simple use case of just wanting wanting to directly replace a specific format for a raw format value, which is possible regardless and is just a matter of how best to allow it being done. Shouldn't we do the same for other formats in the codebase? I see a lot |
How is this different use case? If the goal is to allow customization of the date format used in the forum by a specific user, then |
It should by the way. There is no point if it doesn't. Probably just a mistake.
You can't override functions in flarum, so I'm not following how that's related. I'm not sure I understand why you are against the use case of: as a user I want to be able to customize the scrubber date format. |
My bad, I didn't search in tsx files. Also, the formats in admin panel is currently not considered. |
@YUCLing I've pushed some changes, mainly to pass the ID to the callbacks as that's more useful than a changing final format. Can you check the changes and let me know if you're good to merge this? |
@SychO9 LGTM |
Fixes flarum-lang/chinese-simplified#23 and flarum-lang/chinese-simplified#27 (in another way)
Changes proposed in this pull request:
This PR adds some time formats to dayjs, which makes the customized time formats used by Flarum localizable inlocale
object of dayjs locales.This PR makes Flarum formats all date time using the formats from the language packs.
The PR also made some improvements to
humanTime
andliveHumanTimes
's comments.Reviewers should focus on:
The new formats' naming and whether is it a good implementation.All language packs should contain the following formats after this is merged:
f
andF
: ForhumanTime
ff
andFF
: For scrubberIt's not necessary though, a fallback will be used if they are not provided.Check if all date time are formatted using the format from the language pack.
Although I've tested on my local Flarum installation, it would be nice for you to test it again.
Screenshot
QA
All places wherehumanTime
is used and post stream's scrubber.Modify date time formats in locale and see if it works.
Necessity
Confirmed
composer test
).Required changes: